package niuke;

/**
 * description:
 * author:张腾
 * date:2021-06-29
 */

/**
 * 输入一棵二叉树，判断该二叉树是否是平衡二叉树。
 * 在这里，我们只需要考虑其平衡性，不需要考虑其是不是排序二叉树
 * 平衡二叉树（Balanced Binary Tree），具有以下性质：它是一棵空树或它的左右两个子树的高度差的绝对值不超过1，并且左右两个子树都是一棵平衡二叉树。
 *
 * 注：我们约定空树是平衡二叉树。
 */
public class NC62 {
    public boolean IsBalanced_Solution(TreeNode root) {

        if (root==null) return true;
        return reCur(root)==-1?false:true;
    }

    public int reCur(TreeNode root){
        if (root==null) return 0;
        int left = reCur(root.left);
        if (left == -1) return -1;
        int right = reCur(root.right);
        if (right == -1) return -1;

        return Math.abs(left - right) < 2 ? Math.max(left, right) + 1 : -1;
    }
}
